# シフトレジスタによる SRAM 型とフラッシュメモリ型 FPGA の ソフトエラー耐性の比較

## 河野 雄哉 附田 悠人 古田 潤 小林 和淑

京都工芸繊維大学 工芸科学研究科

あらまし 本稿では、SRAM 型 FPGA とフラッシュメモリ型 FPGA に 50,000 段のシフトレジスタを実装し、白色中 性子ビームを照射して放射線耐性の実測を行い、その評価結果を述べる。結果、FPGA 内に搭載されているフリップ フロップのソフトエラー率は SRAM 型、フラッシュメモリ型ともに約 30 FIT/Mbit 程度で大きな差はなかった。し かし、コンフィグレーションメモリ (CRAM) の耐性を表す平均故障時間は SRAM 型では 3.8 × 10<sup>7</sup> hour/failure、フ ラッシュメモリ型は 5.5 × 10<sup>9</sup> hour/failure となり、フラッシュメモリ型は SRAM 型よりも約 140 倍ソフトエラー耐 性が高いことが確認出来た。SRAM 型にソフトエラー対策を施さない場合は、フラッシュメモリ型よりも平均故障時 間が短いため長時間連続で使用する場合には定期的に再起動やメモリスクラビングを行い、CRAM 内で発生したエ ラーを取り除く必要がある。

キーワード ソフトエラー、SRAM型 FPGA、フラッシュメモリ型 FPGA、白色中性子

# Measuring SER by Neutron Irradiation Between Volatile SRAM-based and Nonvolatile Flash-based FPGAs

## Yuya KAWANO, Yuto TSUKITA, Jun FURUTA, and Kazutoshi KOBAYASHI

Graduate School of Science and Technology, Kyoto Institute of Technology

Abstract We implemented 50k-bit shift registers on SRAM-based and flash-based FPGAs to investigate their radiation hardness using neutron irradiation. As a result, soft error rates of flip flops on both FPGAs are around 40 FIT/Mbit. Mean time to failure (MTTF) in the SRAM-based one is  $3.8 \times 10^7$  hour/failure, while MTTF in flash-based one is  $5.5 \times 10^9$  hour/failure. The MTTF of the flash-based FPGA is at least 140x longer than that of the SRAM-based one. Those results clearly show that in the SRAM-based FPGA without Error Correct and Check code (ECC) must be rebooted or configuration memory must be refreshed much more frequently than the flash-based one.

Key words Soft error, SRAM-based FPGA, Flash-based FPGA, Spallation neutron

# 1. 序 論

FPGA (Field Programmable Gate Array) は自動車、家電、 ネットワーク機器など様々な製品に用いられている。FPGA は従来の集積回路の1つである ASIC (Application Specific Integrated Circuit) に比べてデザインごとのマスクの作成が不 要であることや、製造された後でも回路を自由に書き換えるこ とが出来るなどのメリットを持つ[?]。FPGA や ASIC などの 集積回路の微細化や高集積化することにより電子機器を小型化、 高性能化させることが可能となった。一方で、微細化に伴い、 ソフトエラーなどの信頼性低下の問題が顕在化している。ある 企業では、微細化に伴う宇宙線起因のソフトエラーが増加して きたことを背景にその対策費用として数十億円規模の減益に見 舞われた例もある [?]。

ソフトエラーとは α 線や中性子線といった粒子線が原因と なって発生する一過性のエラーであり、これらの粒子線がデバ イス内を通過またはデバイス内で原子と衝突した際に生成され る電子正孔対により SRAM (Static Random Access Memory) やフリップフロップなどの保持値が反転する現象である。一 過性のエラーは再起動を行うことで修復可能であるが、FPGA の場合はより重大な問題となる。FPGA 内にある SRAM や フリップフロップは通常ソフトエラー対策が施されていない。 CRAM (Configuration RAM) 内でソフトエラーが発生する と、保存している回路が変更されてしまい正常に動作しないこ とがある [?]。

CRAM を不揮発性メモリやアンチヒューズなどに置き換え



図1 ソフトエラーの発生原理

ることでソフトエラー耐性が向上するが、FPGA 内に搭載され ているフリップフロップなどの記憶素子は、通常ソフトエラー 耐性を持たない。FPGA は多様な用途があるため、フリップフ ロップなどの記憶素子においてもソフトエラー耐性を評価する 必要がある。

ソフトエラーの耐性指標には FIT (Failure In Time) が用い られる。FIT は一定時間あたりの故障率を表す単位であり、1 FIT は 1 つのデバイスにおいて 10<sup>9</sup> 時間に 1 回のエラーが発 生することを表す。対象のデバイスが 100 万個になれば、1000 時間に 1 回のエラーになるため、LSI のように市場に大量に流 通するものでは、頻繁にどこかでエラーが発生することになる。 一般に 1000 FIT 以下であれば使用に問題はないとされるが、 自動車や医療機器などの人命に関わる機器では 1 度のエラーが 深刻な問題となるため、高信頼性が必須である [?] [?]。

先行研究ではプロセスノードの違いや、コア電圧動作時の 温度の違いからソフトエラーの信頼性を比較している。[?] で は、プロセスノードの違いによって CRAM や BRAM (Block RAM) などの FPGA 内部に組み込まれているメモリのソフト エラー耐性を報告している。[?] では、FPGA の様々なメモリに 供給する電圧や、温度を変化させることで、ソフトエラー耐性 にどのように影響するか述べている。[?] では様々なエネルギー を持つ重イオンを照射し、CRAM やフリップフロップなどの ソフトエラー耐性を評価している。

本稿では SRAM 型 FPGA とフラッシュメモリ型 FPGA を 用いて、各 FPGA にシフトレジスタを実装し、フリップフロッ プと CRAM のソフトエラー耐性の比較を中性子線照射測定に より行った。第2章では、ソフトエラーについて述べる。第3 章では、使用した FPGA と照射した中性子線について述べ、第 4章で測定方法について述べる。第5章で実測結果について述 べ、第6章でまとめる。

## 2. ソフトエラー

ソフトエラーとは、ハードウェアで発生する永久故障とは異 なり、SRAM やフリップフロップなどの記憶素子の保持値が一 時的に反転する一過性のエラーのことである。地上ではチップ のパッケージ材料に含まれる α 粒子や高エネルギー中性子が原 因であり、宇宙空間では重イオンが主な原因となっている。本 章では、中性子線により発生するソフトエラーや FPGA で発 生するソフトエラーについて述べる。



⊠ 2 Single Event Upset

#### 2.1 中性子線起因のソフトエラー

図1にソフトエラー発生原理を示す。荷電粒子がトランジス タ内を通過、またはトランジスタ内部のSi原子と衝突するこ とで電子正孔対が生成され、発生した電子がドレインに収集さ れることによってソフトエラーが発生する[?]。宇宙線が大気 中の原子核と衝突することで発生する高エネルギー中性子が基 板内のSi原子と衝突することで α 粒子や荷電粒子を生成する。 さらに、パッケージやボンディングワイヤなどに含まれる放射 性不純物も α 粒子を放出する。これらの粒子が拡散層近傍を通 過することで電子正孔対を生じ、ソフトエラーを引き起こす。

#### 2.2 SEU (Single Event Upset)

SEU とは SRAM やフリップフロップ等のデータを保持して いる部分に荷電粒子が突入することで電子正孔対を生成し、保 持値を直接反転させることで発生するソフトエラーのことであ る。SEU によりソフトエラーが発生する様子を図 2 に示す。

インバータを形成する PMOS と NMOS のうち、ソフトエ ラーが起こりやすいのは NMOS である。これは電子の移動度 が正孔の移動度よりも大きいため、粒子線の突入により発生し た電子が NMOS では収集されやすいためである [?]。SEU は 1 つの粒子で反転するビット数に応じて SBU (Single Bit Upset) と MCU (Multiple Bit Upset) の 2 種類に分類される。SBU は 1 ビット反転のエラー、MCU は複数ビット反転のエラーを 表す。

#### 2.3 ファームエラー

粒子線が CRAM に突入した場合、LUT (Look-Up Table) に 保存している出力値が変わることで、回路の機能が変更された り、配線ブロックの保持値が変わることで配線方向が変更され てしまうことがある。ここではこれをファームエラーと呼ぶ。

ファームエラーは FPGA や PLD (Programmable Logic Device) などのデバイスで発生し、CRAM のように回路情報を保 存するメモリを搭載している集積回路で発生するエラーであ る。ASIC のように製造時に回路が形成される集積回路では発 生しない。ファームエラーは回路の機能を変更するため、大規 模なシステムの一部で発生した場合では深刻な問題となる [?]。 ファームエラーは CRAM に元のコンフィグレーションを上書 きすることで修正可能であるが、再度書き込むことが困難な場 合では対策が困難である。

#### 2.4 FPGA のソフトエラー対策

CRAM に用いられている SRAM、LUT を構成する SRAM、 順序回路を実現するフリップフロップには通常ソフトエラー対 策が施されていない。SRAM 型 FPGA ではフラッシュメモリ 型 FPGA、アンチヒューズ型 FPGA とは異なり、ファームエ

-2 -

表1 使用した FPGA の特徴

| EDCA    | SRAM 型     | フラッシュメモリ型   |
|---------|------------|-------------|
| ГРGА    | FPGA       | FPGA        |
| プロセスノード | 28 nm CMOS | 28 nm SONOS |
| CRAM    | SRAM       | フラッシュメモリ    |
| コア電圧    | 1.0 V      | 1.0 V       |
| FF の数   | 65.2k      | 300k        |

ラーが発生するため ECC (Error Check and Correct code) を 用いて発生したエラーを訂正することで抑制することが可能で ある。

ECC は本来の情報ビットに検査ビットを付与することで、ビット反転を検出、訂正する機能である。ECC の中でも SECDED (Single-bit Error Correction Double-bit Error Detection) は、 1 ビットのエラーを修正、2 ビットのエラーを検出することが可能である [?]。その他にも定期的に CRAM を上書きするメモリスクラビングを行うことで、ソフトエラー耐性を向上させることが可能である [?]。

# 3. 実験に用いる FPGA

SRAM 型 FPGA とフラッシュメモリ型 FPGA に白色中性 子を照射して実測評価を行う。表 1 にそれぞれの FPGA の特 徴を示す。SRAM 型 FPGA には 28 nm CMOS プロセスで製 造されており、コア電圧が 1.0 V の Xilinx 社の Spartan-7 を 用いた。CRAM は SRAM で構成されており、電源を OFF に すると保存していた回路が消去されるため、外付けフラッシュ メモリなどにコンフィグレーションデータを保存しておき、起 動時に読み込む。

フラッシュメモリ型 FPGA には Microsemi 社の PolarFire を 用いた。この FPGA は 28 nm SONOS (Silicon-Oxide-Nitride-Oxide-Silicon) CMOS プロセスで製造される。SONOS 構造は ASIC のチップ上でフラッシュメモリを集積化する際に用いら れる構造であり、不揮発性のため一度書き込むと電源を OFF しても回路は消去されない。フローティングゲート型のフラッ シュメモリの書き込み電圧に比べ、低い電圧で書き込み動作を 行うことが可能である。書き込まれた回路は電源を入れるとす ぐ読み込まれるため、LAPU (Live At Power Up) が可能であ る。コア電圧は 1.0 V である。

#### 4. 中性子線によるソフトエラー耐性の評価

中性子照射実験は大阪大学核物理研究センター (RCNP: Research Center for Nuclear Physics) で実施した。図3にニュー ヨークの海面レベルに降り注ぐ中性子線のスペクトルと RCNP で照射を行った白色中性子のスペクトルをまとめた図を示す。 RCNP のビームのスペクトルは地上に降り注ぐ中性子線のスペ クトルと似ており、線量を 10<sup>8</sup>~10<sup>9</sup> に加速するため短時間で 地上における中性子線の影響を評価することが可能である。

#### 4.1 測定方法

図4に実験時の測定系のブロック図を示す。初めに各 FPGA ボードに PC から構成情報の書き込みを行う。SRAM 型 FPGA



図3 ニューヨークの海面レベルのスペクトルと正規化した RCNP の ビームスペクトル



図 4 実験時の測定系



図5 照射時の様子

は DUT (Device Under Test) ボード上に搭載されているフラッ シュメモリにコンフィグレーションデータを保存する。後で述 べる通り、フラッシュメモリ型 FPGA ではファームエラーが 発生しないため、DUT ボード上の SPI フラッシュについても ソフトエラー耐性が高いと考えられる。SRAM 型 FPGA のコ ンフィグレーションデータは DUT ボード上の SPI フラッシュ に保存した [?]。FPGA への入力信号はパルスジェネレータか ら発生させ、出力信号をロジックアナライザで保存する。PC も FPGA 同様ソフトエラーの影響を受けるため、照射室の外 に設置し CAT5 ケーブルを用いて USB ケーブルを延長し、照 射室と接続することで、照射室外から制御を行う。FPGA で は 2.3 節で述べたファームエラーが発生する。今回の測定で は ECC などのソフトエラー対策は施していないため、SRAM 型 FPGA においてはファームエラーが発生する可能性が高い。

| 私2 日本ITCCの例だ时间 |      |          |  |  |
|----------------|------|----------|--|--|
| 照射時間 [分]       | 測定回数 | 測定時間 [分] |  |  |
| 0.5            | 227  | 113.5    |  |  |
| 1              | 95   | 95       |  |  |
| 2              | 118  | 236      |  |  |
| 3              | 67   | 236      |  |  |
| 5              | 21   | 105      |  |  |
| 10             | 21   | 210      |  |  |
| 総測定時間 [分]      |      | 960.5    |  |  |

表 2 各条件ごとの測定時間

ファームエラーにより書き込んでいた回路が故障した場合、電 源装置により FPGA を再起動を行うことで正常なコンフィグ レーションデータを上書きし、測定を続ける。

図5に実験時の様子を示す。白色中性子ビームが測定対象で ある各 FPGA チップの中心を通過するように評価ボードを固 定し、加速器によって発生した白色中性子を各 FPGA に照射 する。ビーム照射口における加速係数は 4.17 × 10<sup>8</sup> であるが、 各 FPGA はビーム照射口から 65 cm、80 cm 離れて設置して おり、ビーム口から距離が離れるにつれてビームの flux が減少 するため、5 章で述べる結果は距離による減衰を考慮して導出 している。

実測の手順を以下に示す。

(1) 初期値としてフリップフロップ (FF) で構成した 500 段ごとに 0,1 が変化するチェッカーボードパターンを書き込む

(2) クロック信号を停止し中性子ビームを照射する

(3) クロックとシフトレジスタの入力信号を入力し、保持 値の読み出しと書き込みを同時に行う

(4) (1)~(3)を繰り返す

今回の測定では、フリップフロップのエラーは SBU のみを 考慮する。FPGA 内の FF は隣り合わせて配置されておらず、 MBU が発生する確率は SBU に比べて極めて低いと考えられ るからである。30 秒から 10 分毎に保持値を読み出した。表 2 に各条件ごとの測定回数と総測定時間を示す。

### 5. 測定結果

図6に観測されたシフトレジスタの出力波形の代表例を示 す。今回の測定では4種類のエラーパターンが観測された。図 6(a) はフリップフロップでSBUが発生した際に得られる波形 である。図6(b) は縮退故障 (Stack-at Fault) であり、出力の 論理値が0または1に固定されてしまう。論理値が0,1で固 定される故障をそれぞれ Stack-at 0故障、Stack-at 1故障と呼 ばれる。周期的なバーストエラーは500段ごとに0、1の値を 初期値として保持させていたにも関わらず、出力では500段で はない間隔になってしまうエラーのことである。出力の間隔の 変化に規則性はなく、ランダムなものであった。図6(c) は出力 が複数ビットに渡り消滅しているエラーである。このエラーは データの信号の入出力に用いているパターンジェネレータ、ロ ジックアナライザで生じたエラーであると考えられるため、測 定結果からは除外する。

縮退故障、周期的なバーストエラーは共にシフトレジスタを





図7 CRAM の各条件ごとのファームエラー発生率



図 8 CRAM の MTTF

動作させるクロック信号を入力しても正常にシフト動作が確認 できなかった。この故障が起こった場合には再起動を行い、コ ンフィグレーションデータを上書きすることで正常に動作した ためこれらのエラーはファームエラーに分類する。縮退故障、 周期的なバーストエラーはシフトレジスタ内の配線がエラーに よって変更され、意図しない箇所で短絡したことにより発生し たと考えられる。

図7にSRAM型FPGAで発生した図6(b)のエラー発生回数を各条件ごとにまとめたものを示す。今回の測定ではフラッシュメモリ型FPGAではファームエラーは1度も発生しなかった。一方でSRAM型FPGAでは、全条件においてStack-at0の条件が最も高い割合を占めており、照射時間が増加するにつれてファームエラーの発生割合も増加することが確認出来た。 照射時間を増加するとFPGA内にエラーが蓄積し、シフトレジスタを動作させるさいに回路が故障する確率が増加するためであると考えられる。



図9 各 FPGA のフリップフロップのソフトエラー率

図 8 に各 FPGA の平均故障時間 (MTTF: Mean Time To Failure) を示す。ただし、フラッシュメモリ型 FPGA では ファームエラーが発生しなかったため、エラーが1 回発生した ものとしてグラフを記載している。MTTF は稼働を始めてか ら故障するまでの平均時間を示す。MTTF の値が大きいほど ファームエラー耐性が高いことを表している。MTTF は式(1) で求められる。

$$MTTF [Failure/hour] = \frac{N_{Ferror} \times AF}{t_{mt}}$$
(1)

MTTF はファームエラー数  $N_{\text{Ferror}}$ 、加速係数 AF、総測定 時間  $t_{\text{mt}}$ を用いることで求める。フラッシュメモリ型 FPGA のファームエラー耐性は SRAM 型 FPGA に比べ、少なくと も 140 倍の耐性を持つことが確認できた。メモリに用いられて いる SONOS 構造はコア電圧である 1.0 V よりも大きい電圧 を印加しないと書き込みや消去を行うことが出来ない。一方で SRAM は粒子線により生成される電荷により簡単に反転して しまう。

図 9 に照射時間ごとのソフトエラー率 (SER: Soft Error Rate) と全条件の平均ソフトエラー率を示す。エラーバーは信 頼区間 95% である。SER は 1 Mbit あたりの FIT 率を表して おり、SER が低いほどソフトエラー耐性が高いことを表してい る。SER は式 (2) で求められる。

$$SER [FIT/Mbit] = \frac{N_{Serror} \times 10^9 \times 1024^2}{t/60 \times AF \times N_{FF}}$$
(2)

SER はフリップフロップで発生したソフトエラー数  $N_{Serror}$ 、 照射時間 t [分]、シフトレジスタの段数  $N_{FF}$ 、AF を用いるこ とで求められる。表 3 に今回得られた平均ソフトエラー率と ベンダーのテストレポートの結果を示す。テストレポートでは 4,000 段のシフトレジスタに間隔の異なる 2 種類のチェッカー ボードパターンを用いた動的試験を行っており、SER はそれぞ れ 460 FIT/Mbit と 230 FIT/Mbit である [?]。一方で今回の 測定で得られた SER は SRAM 型、フラッシュメモリ型共に 30 FIT/Mbit 程度であった。

この原因は測定方法の違いによるものであると考えられる。 今回用いた測定方法は静的試験であるのに対し、Microsemi社 では動的試験で測定を行っている。動的試験の場合、静的試験 に比べシフトレジスタのクロックが常に入力されており、SET

表 3 フリップフロップの SER の比較

|                       | CRAM  | SER [FIT/Mbit] |  |
|-----------------------|-------|----------------|--|
| 測定結果                  | SRAM  | 28.2           |  |
| (静的試験)                | フラッシュ | 34.5           |  |
| ベンダーテストレポート           | フラッシュ | 460            |  |
| (動的試験)[?]             | ///// | 400            |  |
| ベンダーテストレポート           | フラッシュ | 230            |  |
| (動的試験,slowed-down)[?] | ///// | 230            |  |

表 4 CRAM の CS の比較

|                          | CRAM  | CS [/bit]                       |
|--------------------------|-------|---------------------------------|
| 測定結果                     | SRAM  | $6.68 \times 10^{-15}$          |
| (静的試験)                   | フラッシュ | 0                               |
| ベンダーテストレポート<br>(動的試験)[?] | SRAM  | $6.99 \times 10^{-15} \pm 18\%$ |

(Single Event Transient) パルスの影響を受けやすいため、SER に差が生じたと考えられる。この結果より、フリップフロッ プのソフトエラー耐性を向上させるには多重化回路を用いた り、ソフトエラーに強いフリップフロップを搭載する必要があ る[?]。

表4に CRAM の CS (Cross Section) と今回得られた結果を CS に変換したものを示す [?]。CS は式 (3) で求められる。

$$CS \ [/bit] = \frac{N_{\text{Ferror}}}{N_{\text{bit}} \times AF \times t_{\text{mt}}} \tag{3}$$

CS はエッセンシャルビット数 N<sub>bit</sub>、N<sub>Ferror</sub>、AF、t<sub>mt</sub> を用 いて求めた。エッセンシャルビットとは、CRAM を構成する ビットのうち搭載した回路に関係するビットを表しており、こ のビットが反転することで搭載した回路が変更されてしまう。 ただし、エッセンシャルビットが反転することで必ず機能に影 響を及ぼすとは限らない [?]。実験に用いたシフトレジスタの エッセンシャルビット数は 3,326,260 ビットである。結果を比 較すると、CRAM の CS はベンダーの CS の誤差率の範囲内に 収まっていることが確認出来た。CRAM の CS をより小さく するには、ECC や定期的にメモリスクラビングを行うことが 必要である。

## 6. 結 論

本研究では、SRAM 型とフラッシュメモリ型の2種類の FPGAに白色中性子を照射することでソフトエラー耐性を評価 した。

初めにソフトエラーについて述べた。FPGA では ASIC と 異なり、CRAM 内でソフトエラーが発生することにより、保存 している回路が変更されてしまうファームエラーが発生する。 今回は CRAM で発生するファームエラーの耐性と FPGA に 搭載されているフリップフロップで発生するソフトエラーの耐 性を同時に評価した。

フリップフロップのソフトエラー率は2種類の FPGA に大 きな差は見られなかったが、CRAM の平均故障時間において はフラッシュメモリ型 FPGA は SRAM 型 FPGA に比べ、少 なくとも 140 倍長いことが確認出来た。これは、フラッシュメ モリ型 FPGA の持つ SONOS 構造が SRAM よりも放射線耐 性が高いためである。フラッシュメモリ型 FPGA は地上で長時間に渡り再書き込みを行わずに動作させることが可能であるが、SRAM 型 FPGA は再起動やメモリスクラビングを用いることで定期的に CRAM からエラーを取り除く必要がある。

## 謝辞

本研究は、JST-OPERA、JPMJOP1721 の支援を受けたも のである。中性子照射測定は大阪大学核物理研究センターで行 われたものであり、測定の際に有益な助言を頂いた福田光宏教 授に深く感謝致します。